<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
<script>
    // 发布者
    class Dep {
      constructor () {
        this.subs=[]
      }
      // 添加订阅者
      addSub (sub) {
        if (sub&&sub.update) {
          this.subs.push(sub)
        }
      }
      // 发布通知
      notify () {
        this.subs.forEach(sub=>{
          sub.update ()
        })
      }
    }
    // 订阅-观察者
    class Watch {
      update (){
        console.log('update')
      }
    }
    let Deps=new Dep()
    let Watchs=new Watch()
    Deps.addSub(Watchs)
    Deps.notify()
</script>
</body>
</html>
